草庐IT

c++ - 函数成员中的 enable_if 用于 void 和继承

全部标签

ruby - 为什么 block 不像方法那样继承调用者的 $SAFE 级别?

当$SAFE=4的线程调用方法时,该方法以相同的$SAFE级别运行:deftest_methodraise"valueof$SAFEinsidethemethod:#{$SAFE}"endt=Thread.new{$SAFE=4;self.test_method};t.join=>RuntimeError:valueof$SAFEinsidethemethod:4但是,当一个block被调用时,它似乎使用了来自其原始上下文的$SAFE:test_lambda=lambdadoraise"valueof$SAFEinsidethelambda:#{$SAFE}"endt=Thread.n

ruby - ruby 中的数据库连接池

我刚开始使用Ruby,正在玩Sinatra,但找不到在请求之间共享数据库连接的方法。我来自Java网络开发,你必须做的基本事情之一就是汇集数据库连接,所以我确信Ruby中存在类似的东西,但我找不到它。ActiveRecord和DataMapper提供此功能,但我不需要ORM,只想进行常规SQL查询。Sinatra是否有一些特定的方法,或者所有基于Rack的应用程序是否有通用方法? 最佳答案 要保持连接,您只需要创建一个实例变量(无论如何Sinatra应用程序只是对象)或一个全局变量。或者为您管理连接的类。我见过的大多数Ruby数据库

ruby-on-rails - 从 rspec 中的助手规范访问 session

我的ApplicationHelper中有一个方法可以检查我的购物篮中是否有任何元素moduleApplicationHelperdefhas_basket_items?basket=Basket.find(session[:basket_id])basket?!basket.basket_items.empty?:falseendend这是我必须测试的助手规范:require'spec_helper'describeApplicationHelperdodescribe'has_basket_items?'dodescribe'withnobasket'doit"shouldretu

ruby - 如何在 Chef Recipe 中使用 not_if

我是Chef的新手,所以我对条件not_if在执行资源中的工作方式有些困惑。我知道如果命令返回0或true,它会告诉Chef不要执行命令;但是,在我的代码中,它显然仍在运行命令。下面的代码应该创建一个用户(及其密码)和一个数据库;然而,如果用户和数据库已经存在,它不应该做任何事情。用户、数据库和密码在属性中定义。以下是我的代码:execute"create-user"docode=Chef给我以下错误:在资源“execute[create-user]”上执行操作run时出错...[2013-01-25T12:24:51-08:00]致命:Mixlib::ShellOut::ShellC

ruby-on-rails - 如何遍历 ruby​​ 中的 yaml 哈希结构?

我的yaml文件中有一个HashMap,如下所示。我如何在简单的ruby​​脚本中遍历它?我想在迭代期间将键存储在我的ruby​​程序中的一个变量和另一个变量中。source_and_target_cols_map:-com_id:community_idreport_dt:note_datesitesection:site_sectionvisitor_cnt:visitorsvisit_cnt:visitsview_cnt:viewsnew_visitor_cnt:new_visitors我从yaml文件中获取数据的方式如下:#!/usr/bin/envrubyrequire'ya

AppleScript 中的 Ruby 风格字符串插值

有没有办法在AppleScript中实现Ruby风格的字符串插值?我需要一种灵活的方式来创建字符串模式。ruby:fn="john"=>"john"ln="doe"=>"doe"addresses=[]=>[]addresses["jdoe@company.com"]addresses["jdoe@company.com","john.doe@company.com"]苹果脚本:setfnto"john"setlnto"doe"settheAddressesto{}#jdoe@company.comcopy[somethinghere]&"@company.com"totheendof

ruby-on-rails - Rails 中的匿名用户——安全考虑?

我正在考虑在Rails中实现某种形式的匿名用户系统。我需要让人们在不实际创建帐户的情况下做事(创建记录、查看他们创建的内容等)。一旦他们创建了一个帐户,一切都会持续存在,而不会因清除cookie或其他东西而丢失它。现在,我认为这非常简单。在用户模型中有一个is_anonymous字段,并使用类似这样的东西来访问当前登录的用户:deffind_usersession[:user_id]||=create_new_anonymous_user.idend假设session持续了一段合理的时间,并且sessioncookie没有过期,那应该可以让一切顺利运行。但是,我的这一部分确信我遗漏了一

ruby-on-rails - state_machine 仅适用于新记录

我似乎无法获得state_machinegem(http://github.com/pluginaweek/state_machine/)来处理现有记录(它可以在新记录上正常工作)。这是我的模型:classComment:pendingdoevent:publishdotransitionall=>:publishedendendend这是一个演示该问题的IRBsession(我做了ActiveRecord::Base.logger=Logger.new(STDOUT)以使其更易于阅读):>>c=Comment.new=>#>>c.state=>"pending">>c.publish

ruby - 这是 &&= 在 Ruby 中的合理用法吗?

在SOquestion2068165一个答案提出了使用这样的东西的想法:params[:task][:completed_at]&&=Time.parse(params[:task][:completed_at])作为DRYer的说法params[:task][:completed_at]=Time.parse(params[:task][:completed_at])ifparams[:task][:completed_at]paramsHash将来自(Rails/ActionView)表单。这是众所周知的||=习语的一种推论,如果LHS不是nil/false则设置值。像这样使用&&

ruby-on-rails - Ruby 中的 Object::private 和 Object::public 是什么?

这些方法是什么?覆盖它们有多糟糕?irb(main):001:0>Object::respond_to?('private',true)=>trueirb(main):002:0>Object::respond_to?('public',true)=>true当尝试为模型定义一个名为private或public的范围时,问题出现在Rails中。由于修复了错误https://rails.lighthouseapp.com/projects/8994/tickets/4167-activerecord-named_scope-using-columns-as-the-name-is-bug